AMENDMENTS TO THE CLAIMS 

This listing of claims will replace all prior versions and listings of claims in the 
application. The following listing provides the amended claims with the amendments marked 
with deleted material crossed out and new material underlined to show the changes made. 

Listing of Claims: 

1.-3. (Canceled) 

4. (Previously Presented) A method of processing a plurality of image processing 
routines on a particular processor using a cache of the particular processor, each routine in the 
plurality of routines processing at least one frame of video data, the method comprising: 

a) determining an initial list comprising a plurality of routine identifiers positioned in a 
specific order which when executed by the particular processor according to the specific order 
produce a particular effect, the plurality of routine identifiers identifying the plurality of image 
processing routines, each routine identifier in the plurality of routine identifiers identifying a 
corresponding routine in the plurality of routines; 

b) grouping at least two routine identifiers of the plurality of routine identifiers into a set 
of routine identifiers that identify a set of routines; 

c) modifying the initial list of routine identifiers to indicate the grouping of the at least 
two routine identifiers to produce a modified ordering of the initial list of routine identifiers, 
wherein said grouping and said modifying are performed by a set of instructions executed by the 
particular processor; 
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d) executing the routines identified in the modified ordering of routine identifiers by 
traversing the modified list of routine identifiers to produce the particular effect, wherein said 
executing comprises executing the identified routines in the modified ordering so that data stored 
in the cache from at least one previous routine is used for processing a subsequent routine that 
produces output stored back into the cache; and 

e) storing output of the routines to a computer-readable medium. 

5. (Currently Amended) The method of claim 4 further comprising: 

determining a size of a band of the frames of video data of the set of routines, each frame 
of video data being comprised of at least two bands where the size of the band is related to a size 
of the cache; and 

modified ordering of the initial list of routine identifiers 

wherein executing the routines identified in the modified list ordering of routine 
identifiers comprises executing the identified routines in two or more passes, a pass of the set of 
routines comprising each routine in the set of routines performing a single processing pass where 
the routine processes at least one band retrieved from the cache to produce output data stored to 
the cache. 

6. (Previously Presented) The method of claim 5, wherein determining the size of 
the band comprises determining the size of a band of the frames of video data so that all data 
processed by and all output data produced by any routine in the set of routines can be stored to 
the cache during a single processing pass of the routine. 

7. (Previously Presented) The method of claim 5, wherein determining the size of 

the band comprises determining the size of a band using the following equation: 
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band size = [(cache size-overhead)/buffer number], 

where the cache overhead is memory space in the cache that is unusable to store data of 
the set of routines and the buffer number is the maximum number of buffers simultaneously 
accessed by the set of routines if the entirety of each frame of video data of the set of routines 
were processed in one processing pass of the set of routines. 

8. (Currently Amended) The method of claim 4 wherein: 

grouping at least two routine identifiers comprises re -ordering a position of a particular 
routine identifier in the initial list of routine identifiers to produce the set of routine identifiers; 
and 

modifying the initial list of routine identifiers comprises modifying the initial list of 
routine identifiers to indicate the re-ordering of the particular routine identifier to produce the 
modified list ordering of routine identifiers. 

9. -25. (Canceled) 

26. (Previously Presented) A method of executing a set of at least two image 
processing routines on a processor using a particular cache, each routine in the set of routines 
processing at least a frame of video data, the method comprising: 

a) determining a size of a band of a frame of video data based on a size of the particular 
cache, a plurality of buffers referenced within said particular cache by said set of routines, and 
cache overhead, wherein the cache overhead is memory space in the particular cache that is 
unusable to store data of the set of routines, wherein the frame of video data is divisible into at 
least two bands; and 
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b) executing the set of at least two routines in at least first and second passes to produce 
a particular effect, wherein the first pass performs a first subset of the set of routines on at least 
one band retrieved from the particular cache to produce output data stored to the particular cache 
and the second pass performs a second subset of the set of routines on the output data of the first 
pass that is retrieved from the particular cache to produce the particular effect that is stored back 
into the particular cache. 

27. (Previously Presented) A method of executing a plurality of image processing 
routines on a processor using a particular cache by reusing data stored in the particular cache, 
each routine in the set of routines processing at least a frame of video data, the method 
comprising: 

a) determining a size of a band of a frame of video data, wherein the frame of video data 
is divisible into at least two bands; and 

b) executing the plurality of routines in at least first and second passes, the first pass 
performing each routine in a first subset of the set of routines on a first band referenced by said 
routine and retrieved from the particular cache, in order to produce output data stored to the 
particular cache, and the second pass performing each routine in a second subset of the set of 
routines on a second band referenced by said routine and retrieved from the particular cache, in 
order to produce output data stored to the particular cache; and 

c) retrieving the output data of the first pass and the output data of the second pass from 
the cache to derive an output for the image processing. 

28. (Previously Presented) The method of claim 27 further comprising determining 
the size of the band based on a size of the cache. 
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29. (Previously Presented) The method of claim 28 further comprising determining 
the size of the band so that all frames of video data processed by and all output data produced by 
any routine in the set of routines can be stored to the cache during a single processing pass of the 
routine. 

30. (Previously Presented) The method of claim 28, wherein determining the size of 
the band further comprises determining the size of the band using the following equation: 

band size = [(cache size-overhead)/buffer number], 

where the cache overhead is memory space in the cache that is unusable to store data of 
the set of routines and the buffer number is the maximum number of buffers simultaneously 
accessed by the set of routines if the entirety of each frame of video data of the set of routines 
were processed in one processing pass of the set of routines. 

3 1 . (Previously Presented) The method of claim 27 further comprising the processing 
of the plurality of bands during a single pass, wherein each band is associated with a separate 
frame of video data. 

32. (Previously Presented) The method of claim 27, wherein the plurality of bands 
retrieved from the cache are associated with a single frame of video data. 

33. (Previously Presented) The method of claim 27, wherein the plurality of bands 
retrieved from the cache are associated with separate frames of video data. 

34. -44. 

45. (Previously Presented) A computer-readable medium that stores a computer 

program comprising executable code, the computer program for executing a set of at least two 

image processing routines on a processor using a particular cache, each routine in the set of 
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routines processing at least a frame of video data, the computer program comprising sets of 
instructions for: 

a) determining a size of a band of a frame of video data based on a size of the particular 
cache, a plurality of buffers referenced within said particular cache by said set of routines, and 
cache overhead, wherein the cache overhead is memory space in the particular cache that is 
unusable to store data of the set of routines, wherein the frame of video data is divisible into at 
least two bands; and 

b) executing the set of at least two routines in at least first and second passes to produce 
a particular effect, wherein the first pass performs a first subset of the set of routines on at least 
one band retrieved from the particular cache to produce output data stored to the particular cache 
and the second pass performs a second subset of the set of routines on the output data of the first 
pass that is retrieved from the particular cache to produce the particular effect that is stored back 
into the particular cache. 

46. (Previously Presented) A computer-readable medium that stores a computer 
program comprising executable code, the computer program for executing a plurality of image 
processing routines on a processor using a particular cache by reusing data stored in the 
particular cache, each routine in the set of routines processing at least a frame of video data, the 
computer program comprising sets of instructions for: 

a) determining a size of a band of a frame of video data, wherein the frame of video data 
is divisible into at least two bands; and 

b) executing the plurality of routines in at least first and second passes, the first pass 
performing each routine in a first subset of the set of routines on a first band referenced by said 
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routine and retrieved from the particular cache, in order to produce output data stored to the 
particular cache, and the second pass performing each routine in a second subset of the set of 
routines on a second band referenced by said routine and retrieved from the particular cache, in 
order to produce output data stored to the particular cache; and 

c) retrieving the output data of the first pass and the output data of the second pass from 
the cache to derive an output for the image processing. 

47. (Previously Presented) The computer-readable medium of claim 46 further 
comprising determining the size of the band based on a size of the cache. 

48. (Previously Presented) The computer-readable medium of claim 47, wherein 
determining the size of the band comprises determining the size of a band of the frame of video 
data using the following equation: 

band size = [(cache size-overhead)/buffer number], 

where the cache overhead is memory space in the cache that is unusable to store data of 
the set of routines and the buffer number is the maximum number of buffers simultaneously 
accessed by the set of routines if the entirety of each frame of video data of the set of routines 
were processed in one processing pass of the set of routines. 

49. (Previously Presented) The computer-readable medium of claim 46, wherein the 
plurality of bands retrieved from the cache are associated with separate frames of video data. 

50. -51. (Canceled) 
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